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METHOD AND SYSTEM FOR INJECTING NEW 
CODE INTO EXISTING APPLICATION CODE 

TECHNICAL FIELD 

The present invention relates to modifying existing application 
code and, in particular, to injecting a dynamic link library into an existing 
executable file. 

BACKGROUND OF THE INVENTION 

In current computer systems, there often exists a need for 
modifying the behavior of executable code stored in a pre-existing executable 
file. For the purposes of this application, an "executable file v is any type of code 
image and is not limited to a particular type of executable file or a file with a 
particular file name extension. In particular, the need exists to change the 
behavior of an application without recompiling the application. This need is 
especially apparent in situations where it is impossible or too much work to 
recompile the application. For example, an application may be developed by a 
source company at one site and distributed to a third party vendor at another site. 
The third party vendor may wish to incorporate vendor-specific code into the 
application before redistributing it to an end customer. However, the third party- 
vendor may not have access to the source code that the source company used to 
generate the executable file. Thus, the third party vendor cannot change and 
recompile the source code to generate a new executable file with the vendor- 
specific code. 

As another example, especially relevant in today's extensive 
networking environments, a company may desire to put an existing application 
on the Internet and somehow incorporate licensing code to limit any use of illegal 
copies of the application. Current systems have tried various solutions to 
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incorporate licensing code into an existing application. According to one 
technique, which will be referred to herein as "wrapping," a second application 
program (a wrapper program) is distributed on the network, which includes an 
encrypted version of the original application program. The wrapper program, 
when installed, decrypts the encrypted original application program and then 
proceeds to execute the original application program. To successfully decrypt 
the program, a legitimate end user must provide the proper licensing information 
to enable the decryption to operate. A security hole exists, however, in that, 
while the wrapping program is in the process of decrypting the original 
application executable file, temporary files are created to hold the decrypted 
program code. Once the entire original application program has been decrypted 
and stored in the temporary file, a ;i software pirate" can then make multiple 
copies of the original unencrypted application program in the temporary file and 
can distribute them illegally. 

Further, use of the wrapping technique to incorporate licensins 
provides only limited additional security to a vendor who implements what is 
known as a i: try and buy" licensing program. A try and buy licensing program 
typically distributes an application program with either limited functionality or 
for a limited time of use to enable a potential customer to explore the application. 
Functionality is typically limited, for example, by turning off a set of features. 
Once the potential customer is satisfied, the customer can pay for and license the 
application program properly. If an application program is distributed using the 
wrapping technique to potential customers for the purpose of a try and buy 
program, then, when the program is decrypted and stored in a temporary file, a 
software pirate can determine how to turn on the disabled features or how to 
remove the license expiration data. These security problems can result in the 
distribution of illegal copies, which are hard to detect and monitor in a global 
network environment. 
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In one embodiment, the injection mechanism injects into the 
existing executable file new DLL code and optionally injects additional security 
code, which is provided by the injection mechanism. Preferably, the injected 
security code performs checksum comparisons on some portions of the 
5 executable file, decrypts and executes a previously encrypted portion of the 
executable code, and decrypts and transfers execution control to a previously 
encrypted location in the original executable code. The injection of security code 
helps to prevent modification of the executable file to omit the injected code and 
thereby restore the executable file to its original, unmodified state. In the case of 
jo newly added licensing code, the injected security code aids in preventing illegal 
altering, copying, and distribution of the original executable code. 

The injection mechanism provides two methods for injecting a 
DLL into existing executable code. The first method modifies an import table of 
the executable file to include a reference to the new DLL code. A second method 
15 modifies the executable file to include DLL loader code, which is provided by 
the injection mechanism. The DLL loader code uses system provided calls to 
load the desired new DLL. The injection of security code can be utilized with 
both methods of injecting a DLL. 

The present invention also provides incremental encryption and 
20 decryption techniques, which can be used to further secure any of the injected 
code. The incremental encryption and decryption techniques operate by 
encrypting (and subsequently decrypting) blocks of code of varying sizes, using a 
different key for each block. The decryption code decrypts each block and 
executes the decrypted code, one block at a time, and overwrites each decrypted 
25 block when decrypting a next block. This process ensures that the entire 
unencrypted code is never visible at any one time. 
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BRIEF DESCRIPTION OF THE DRAWINGS 

Figure 1 is a block diagram of a general purpose computer system 
for practicing embodiments of the injection mechanism. 

Figure 2 is a block diagram of a logical format of an executable file 
5 that can be used with the present invention. 

Figure 3 is an overview block diagram of the procedure for 
injecting a reference to a new DLL into an import table of an existing executable 
file. 

Figure 4 is a flow diagram of example code that can be placed into 
10 an injectable DLL in order to incorporate licensing into an existing application. 

Figure 5 is a detailed flow diagram of the steps used by the 
injection mechanism to inject a new DLL using the import table technique. 

Figure 6 is an overview block diagram of the modifications made 
to an executable file by the injection mechanism to inject a reference to a new 
15 DLL using the DLL loader code technique. 

Figure 7 is a flow diagram of the steps used by the injection 
mechanism to inject a new DLL using the DLL loader code technique. 

Figure 8A is a block diagram of the logical layout of an executable 
file after security 7 code has been injected into the executable file using the import 
20 table technique. 

Figure 8B is a block diagram of the logical layout of an executable 
file after security code has been injected into the executable file using the DLL 
loader code technique. 

Figure 9 is an overview flow diagram of the steps performed by the 
25 injection mechanism for injecting security code and data into an executable file. 

Figure 10 is a flow diagram of the steps executed by an incremental 
encryption routine. 
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Figure 1 1 is a detailed flow diagram of the steps performed by the 
injection mechanism to determine the number and size of the encryption blocks 
of data to be encrypted using the incremental encryption technique. 

Figure 12 is an example block diagram of the results of 
5 determining the size of encryption blocks according to the technique of 
Figure 11. 

Figure 13 is a detailed flow diagram of the verify checksum code 
added by the injection mechanism to an executable file. 

Figure 14 is a detailed flow diagram of the steps performed bv 
10 incremental decryption. 

DETAILED DESCRIPTION OF THE INVENTION 

The present invention provides a method and system for modifying 
the behavior of existing executable code by injecting new code into an executable 

15 file. The injection mechanism of the present invention provides techniques for 
injecting a reference to a new dynamic link library ( C1 DLL") which contains new 
code into an existing executable file such that, when the code of the executable 
file is executed, the DLL is automatically loaded and the new code is 
automatically executed. The injection mechanism provides the automatic loading 

20 of the DLL by either modifying a table used by the underlying system to 
automatically load DLLs or by inserting code that knows how to load the DLL. 
Thus, a developer desiring to add new behavior to the existing executable code 
stored in the executable file can do so by providing the new behavior as DLL 
code. The desired new behavior is preferably provided in an initialization routine 

25 of the DLL (e.g., "DLLMain" in the WINDOWS/NT operating system). The 
injection mechanism ensures that the DLL initialization routine is automatically 
executed when the DLL is mapped into the executable code image process space 
and loaded into memory. Thus, using the injection mechanism, any new code 
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A second technique for modifying the behavior of an existing 
application program directly inserts the new executable code into the executable 
file. Using the direct insertion method, an application developer determines 
where in the executable file the new code should be placed and inserts the code 
5 into the executable. After inserting the new code into the existing executable 
file, the application developer adjusts addresses that reference any relocatable 
code or data that follows the inserted code to account for the newly added code. 
However, it is very difficult for an application developer to determine where to 
insert code and to then test the entire application to ensure it works correctly. An 

10 application developer would typically need to disassemble the executable file and 
study the disassembled code to determine where to insert the code. Such 
disassembling and studying is a very time-consuming process. Furthermore, the 
process must be repeated for each application program, and for each version of 
each application program in which the code is to be inserted, 

15 Thus, the need exists to modify the behavior of executable code 

stored in an existing executable file in a manner that is secure and that requires 
minimal testing outside the scope of standalone testing of the code that provides 
the modified behavior. 

20 SUMMARY OF THE INVENTION 

The present invention provides, a method and system for injecting 
new code into already existing executable code within an executable file. The 
injection mechanism provided by the present invention can be used to inject a 
dynamic link library (DLL) that contains the new code or to inject arbitrary code 

25 into an existing executable file. The injection of new code enables the existing 
executable code to perform new behaviors. For example, licensing procedures 
can be added to an existing application by injecting a licensing DLL into the 
application using the injection mechanism. 
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can be added to an existing executable file as long as the new code resides in a 
DLL. Also, because the DLL is separately testable and modifiable, the injection 
mechanism of the present invention reduces the time needed to develop and test 
the new code. 

5 According to the injection mechanism, the reference to the new 

DLL is injected into the existing executable code in one of two ways. According 
to the first method, a DLL is injected into existing code by modifying the import 
table of the existing executable file. An import table is a data structure supported 
by the underlying operating system that indicates the names of DLLs to be 

10 mapped into the executable code when it is run (and loaded if not already loaded 
into memory when the executable file is loaded). The import table also includes 
references to the functions within each listed DLL that are called by code in the 
executable file. (The executable code invokes the functions of a DLL as external 
references.) The second method for injecting a reference into the executable 

15 code modifies the executable code to include DLL loader code, which is 
provided by the injection mechanism. The DLL loader code relies on the 
underlying system to provide a mechanism for loading DLLs at run time. This 
method is useful when no load-time DLL loading mechanism, such as the import 
table mechanism, is provided by the operating system. 

20 The injection mechanism also provides a technique for injecting 

security code into the existing executable file to ensure that neither the injected 
reference to the DLL nor the DLL has been modified. The security code 
injection technique performs and stores checksums on portions of the executable 
file and DLL, encrypts a portion of the executable code in the executable file, and 

25 inserts security code into the executable file. The security code that is inserted 
computes checksums on the various portions of the executable file and the DLL 
and verifies that the checksums are the same as those originally stored. The 
security code also decrypts and executes the previously encrypted portion of the 
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executable code using an incremental decryption process. The incremental 
decryption process ensures that a complete version of the unmodified executable 
file is never visible at any one time. Thus, the injection of security code makes it 
impossible for somebody to recreate an unmodified version of the existing 
5 executable file in a reasonable amount of time. 

The injection mechanism is useful in many scenarios. For 
example, in a globally networked system such as the Internet, licensing code can 
be incorporated into an existing application and distributed on the system by 
injecting the licensing code into the application using the injection mechanism. 

10 The licensing developer creates a new DLL with the new licensing code 
accessible through the initialization function of the DLL. The developer then 
uses the injection mechanism of the present invention to create a modified 
version of the application that includes a reference to the new DLL. This 
modified version is then distributed. Further, the newly injected licensing code 

15 can be made more secure by using the injection mechanism to inject security 
code into the modified application. The injected security code makes it 
impossible to recreate in a reasonable amount of time an unmodified version of 
the application that does not include the injected licensing DLL. 

The injection mechanism is also useful in other scenarios that 

20 require the addition of code to an existing executable file in order to provide 
modified behavior to existing executable code. As an example, the injection 
mechanism can be used to modify a network browser, such as an Internet 
browser, to start and stop applications upon command. In this case, code that 
starts and stops a designated application is created as a new DLL. The DLL that 

25 contains the "start and stop" code is then injected into the browser using the 
injection mechanism. The application to be started and stopped upon invocation 
of a command may be designated, for example, by prompting a user for input. 
Also, the starting and stopping behavior upon command invocation could be 
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provided in the start and stop code using well-known techniques such as a 
graphical button, menu, or keyboard command. 

The injection mechanism also can be used to incorporate additional 
user interface behavior into an existing application. For example, the injection 
mechanism could be used to insert a third-party vendor-specific set of menus into 
an existing application. It is assumed, in this case, that the underlying operating 
system supports calls to add a menu with menu items into an existing application 
menu, as well as the ability to handle events caused by the selection of items 
from the new menu. For example, the MICROSOFT WINDOWS 3.1 operating 
system provides the ''Append Menu;' "Insert Menu," and "Set Menu" functions 
to create and add menus to an application. To add a set of menus, the third-party 
developer creates new code which creates the menus using the underlying system 
calls, places the menu appropriately on the screen, and handles any events 
triggered by the menu items. The newly created menu code is then injected into 
the application using the injection mechanism. 

In a preferred embodiment, the methods and systems of the 
injection mechanism are implemented on a computer system comprising a central 
processing unit, a display, a memory, and other input'output devices. Preferred 
embodiments are designed to operate in an environment that supports shared 
independent code modules, such as the dynamic link libraries provided by- 
various versions of the WINDOWS operating system. Dynamic link libraries 
and their use are discussed further in the Charles Petzold, Programming 
Windows, 2d ed., Microsoft Press, Redmond, 1990, pp. 877-915, which is herein 
incorporated by reference. One skilled in the art will recognize that 
embodiments of the injection mechanism can be practiced in other environments 
that support other types of shared, linkable library modules. 

Figure 1 is a block diagram of a general purpose computer system 
for practicing embodiments of the injection mechanism. The computer system 
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101 contains a central processing unit (CPU) 102, a display 103, a computer 
memory (memory) 104, and other input/output devices 105. The injection 
mechanism 109 preferably resides in the memory 104 and executes on the CPU 
102. The executable code of an application 106 is shown residing in memory 
5 104 after the injection mechanism 109 has injected a reference to a new DLL 107 
and after the injection mechanism 109 has injected security code into the 
executable file. Other programs 108 also reside in the memory 104. One skilled 
in the art will recognize that the preferred injection mechanism can be 
implemented in a distributed environment where more than one computer system 

10 is used to communicate with other computer systems. For example, the 
application executable code 106 may reside on a different computer system from 
the DLL 107 or from the injection mechanism 109. In either case, the injection 
mechanism 109 preferably relies on the operating system to support the loading 
of DLLs across different computer systems. 

15 Because the injection mechanism injects a reference to a new DLL 

and optionally injects security code by adding code into an existing executable 
file, the injection mechanism needs to have knowledge of the different executable 
file formats it wishes to manipulate. Although the mechanism itself operates 
independently of the executable file format, the injection mechanism needs to be 

20 aware of the file format in order to determine the proper locations at which 
references or code should be added. Figure 2 is a block diagram of a logical 
format of an executable file that can be used with the present invention. 
Executable file 201 comprises a header section 205, an application executable 
code section 202, an application import table section 203, and an application 

25 relocatable address table section 204. The term application is included here for 
ease of description, although it will be recognized that the executable file may be 
for some code segment other than an application, for example, a module that 
comprises part of a program, or a DLL. The header section 205 includes pointers 
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to the application executable code section 202, the import data section 203, and 
the relocatable data section 204. 

The executable file format illustrated in Figure 2 is a logical 
representation of the PE file format supported by the MICROSOFT/NT operating 
5 system and other operating systems. The particulars of the PE file format are 
discussed further in Microsoft Portable Executable and Common Object File 
Format, Specification 4.1, Microsoft Corporation, August 1994, which is herein 
incorporated by reference. One skilled in the art will recognize that this file 
format is merely illustrative and that other file formats will work. The executable 

10 file may be comprised of multiple memory segments, which are not necessarily 
contiguous. Other figures of the executable file referred to herein are oriented as 
if they were one logical contiguous sequence of memory addresses. However, it 
will be appreciated that the layout of these other figures as contiguous is for ease 
of description purposes. Also, note that although executable file refers to "file" 

15 in singular, one skilled in the art would appreciate that the injection mechanism 
of the present invention would be operable in an environment where multiple 
files comprise the executable file that is stored in secondary storage. 

As discussed above, the injection mechanism injects a reference to 
a new DLL according to two different methods. The first method modifies the 

20 import table of the executable file, whereas the second method modifies the 
executable file to include DLL loader code that is provided by the injection 
mechanism. The first method for injecting a reference to a DLL is discussed in 
detail with reference to Figures 3 and 5. The second method for injecting a 
reference to a DLL is discussed in detail with reference to Figures 6 and 7. 

25 Figure 3 is an overview block diagram of the procedure for 

injecting a reference to a new DLL into an import table of an existing executable 
file. In Figure 3, executable file 301 contains import table 302. As previously 
mentioned, the import table 302 enables the underlying operating system to 
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determine which DLLs to map into the process space and to load into memory 
when the executable file is loaded into memory for execution. Import table 302 
contains one import entry per DLL. Each import entry, for example entry 303, 
contains the name of the DLL to be loaded and a list of the external functions 

5 defined in the DLL which are referenced by executable file 30 1 . 

To inject new DLL 306, the injection mechanism finds an 
appropriate place to add a new entry into import table 302 and adds a new entry, 
which includes a reference to the injected DLL 306. Specifically, a new import 
entry 307 is inserted into the import table and includes the name of the DLL 304 

10 to be injected and a "dummy" function, herein named the stub function 305. The 
stub function 305 is not actually referenced by the executable code contained in 
executable file 301, but the format of the import table may require the name of at 
least one function to be included in the entry. As can be seen injected in 
Figure3, DLL 306 preferably contains a DLLMain function (the initialization 

15 function), which is automatically invoked by the underlying operating system as 
a result of including the new import entry 307 into import table 302. 

Figure 4 is a flow diagram of example code that can be placed into 
an injectable DLL in order to incorporate licensing into an existing application. 
This licensing code provides an example of code that is added to the DLLMain 

20 routine of the injected DLL 306 of Figure 3 to provide licensing over a network 
such as the Internet. In step 401, the licensing code loads any licensing specific 
data, such as what features of the application are subject to a license, from the 
application executable file. In step 402, the code calls some function within a 
licensing library to determine whether the product is licensed. For example, the 

25 licensing library may provide the ability to encrypt a key as a license, and the 
function referred to in step 402 would then decrypt a stored value and make an 
assessment as to whether the key is still valid. In step 403, if it is determined that 
the product is licensed, then the code continues in step 404, else continues in step 
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405. In step 404, the code determines whether the license has expired and, if so, 
continues in step 405, else returns. In step 405, the code determines whether the 
user wishes to properly purchase the product, and if not, terminates the 
application, else continues in step 406. In step 406, the code obtains purchasing 
5 information, sends it to the distributor, and then waits to receive a response from 
the distributor. In step 407, the code determines whether an error response was 
received from the distributor and, if so, terminates the application, else continues 
in step 408. In step 408, the code determines whether the user wishes to retry the 
licensing procedure with the received licensing data from the distributor and, if 

10 so, continues back to step 402 to process the data, else terminates the application. 

Figure 5 is a detailed flow diagram of the steps used by the 
injection mechanism to inject a new DLL using the import table technique. 
These steps are implemented by the injection mechanism code 109 shown in 
Figure 1. In step 501, the injection mechanism determines the type of the 

15 executable file. Then, in step 502, if it is a known executable file type, the 
injection mechanism continues in step 503, else returns an error. In step 503, the 
routine locates where in the executable file the import table for the application is 
located. For example, according to the executable file format shown in Figure 2, 
the import data ("IData") entry of the header section 205 can be used to locate 

20 application import table 203. Once located, in step 504, the routine creates a new 
import entry that refers to the new DLL and adds the new entry to the import 
table. In step 505, a reference to the stub function of the new DLL is added to 
the import entry. Then, in step 506, the routine adjusts any of the references to 
relocatable addresses in the executable file that numerically follow the added 

25 entry to the import table. This adjustment of relocatable addresses is needed 
because, by adding a new import table entry, the size of the import table has 
changed. Thus, everything that was logically below the import table is moved 
further down. The adjustment of relocatable addresses is similar to the steps 
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performed by a linker/loader mechanism. One such system for adjusting 
addresses using the PE file format is described in Matt Pietrek, "Peering Inside 
the PE: A Tour of the Win32 Portable Executable File Format," Microsoft 
Systems Journal, March, 1994, which is herein incorporated by reference. The 
5 injection mechanism of the present invention preferably does not publicize where 
within the application import table the new entry, which refers to the new DLL, 
is added. It is not important where the entry is added so long as the step of 
adjusting relocatable addresses of step 506 is performed appropriately. By not 
publicizing the location, the amount of time needed to break the security is 

10 increased. In step 507, the routine follows the procedure for injecting security 
code into the executable file, and then returns. Step 507 is optional as discussed 
earlier, and is used to increase the probability that the modified executable file 
will not be able to be unmodified and subsequently executed without the 
modifications. The injection of security code is discussed in detail with reference 

15 to Figure 9. 

Figure 6 is an overview block diagram of the modifications made 
to an executable file by the injection mechanism to inject a reference to a new- 
DLL using the DLL loader code technique. Executable file 601 represents the 
logical state of the executable file before any modifications have been made. 

20 Executable file 601 contains an indicator 603 of the entry point of the executable 
code, which is shown located for the purposes of example at address "xxx." Note 
that the Figure 6 shows a logical layout of an executable file, in which all the 
addresses appear to be sequential and continuous. This logical layout is used for 
the purposes of illustration only as discussed earlier with reference to Figure 2. 

25 The entry point indicator 603 typically points to the first instruction in the 
application executable code segment 602. The instructions comprising 
executable code segment 602 may vary in size depending upon the instruction set 
of the underlying computer system. 
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In Figure 6, executable file 604 represents the logical state of the 
executable file after the injection mechanism has inserted DLL loader code into 
the executable file 604. Specifically, the injection mechanism determines a 
location within the code in which to copy the DLL loader code, copies the DLL 

5 loader code, modifies the code entry point indicator 605 (located at address 
"xxx") to point to the newly added DLL loader code, and stores the value of the 
previous entry point indicator so that it can be accessed when the DLL loader 
code is executed. In this manner, when the executable file is executed, it will 
begin executing at the DLL loader code instead of the code entry point referred to 

10 by indicator 605. The DLL loader code will load the new DLL before executing 
the original application executable code 606. The injected DLL loader code 607 
contains an instruction at the end of the DLL loader code to transfer control back 
to the original application executable code 606. The injected DLL loader code 
607 preferably contains a call provided by the underlying operating system to 

15 load the new DLL. This call contains a reference to the new DLL 608, which 
becomes the injected DLL. As discussed with reference to the import table 
technique shown in Figure 3, the injected DLL 608 contains a DLLMain routine, 
which is automatically called by the operating system LoadDLL system call and 
therefore should contain the modifying behavior that the application programmer 

20 wishes to add to the executable file. For example, the application programmer 
could add the licensing procedures discussed earlier or the user interface 
additions to the DLLMain routine. Injected DLL 608 is presumed to be the same 
as the DLL injected into the executable file 306 using the import table technique 
shown in Figure 3. Alternatively, the injected DLL loading code could directly 

25 invoke a predefined function of the injected DLL. 

Figure 7 is a flow diagram of the steps used by the injection 
mechanism to inject a new DLL using the DLL loader code technique. In 
particular, in step 701, the injection code determines the type of the executable 
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file. In step 702, if the executable file type is known to the injection code, the 
routine continues in step 703, else returns an error because the injection 
mechanism does not know how to inject code into an unknown executable file 
type. In step 703, the routine determines the location of the executable code in 
5 the executable file. In step 704, the routine saves the original application code 
entry 7 point (e.g., the contents of code entry point indicator 603 in Figure 6). In 
step 705, the routine adds the DLL loader code to a predetermined location 
within the located executable code. Similar to the import table technique 
discussed with reference to Figure 5, it is specifically intended that the location 

io where the DLL loader code is placed is not publicized for security reasons. The 
exact location is preferably immaterial to the operability of the invention. In step 
706, the routine resets the code entry point of the application to the address of the 
newly added DLL loader code and in step 707 adjusts any relocatable addresses 
that need adjusting due to the increase in code size at the location where the DLL 

15 loader code was added. In step 708, the injection mechanism code optionally 
injects security code, and then returns. The injection of security code is 
discussed in detail with reference to Figure 9. 

Once the behavioral modifications desired have been added to the 
executable file by means of injecting a DLL according to either the import table 

20 method or the DLL loader method, the executable file when executed will 
perform any behaviors added to the DLL. However, the modifications made by 
injecting a DLL are not without security risks. Specifically, without further 
security measures, a skilled programmer could substitute for the injected DLL 
another DLL which did not perform the associated behaviors. Or, the 

25 programmer could take out the entry in the import table if the import table 
technique is used. Further, a skilled programmer could modify the injected DLL 
loader code to load a dummy DLL instead of the injected DLL. For these 
reasons, the injection mechanism of the present invention provides the added 
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feature of injecting security code into the executable file. Although the 
techniques used to inject the security code are discussed herein in detail, the 
particular locations where certain pieces of encrypted code are stored and the 
particular keys used should preferably not be publicized. These locations and 
5 keys are not needed to use or understand the operations of the present invention 
and are preferably kept secure by the injection mechanism. 

Figure 8A is a block diagram of the logical layout of an executable 
file after security code has been injected into the executable file using the import 
table technique. Executable file 8A01 is shown with import table 8A04 modified 

10 to refer to injected DLL 8A02, as discussed with reference to Figure 3. 
Executable file 8A01 contains a code entry point indicator located at address 
"xxx encrypted application code 8A07, unencrypted application code 8A08, an 
import table 8A04 ; which refers to injected DLL 8A02, and injected security 
code and data 8A05. The injection mechanism inserts security code and data by 

15 adding the appropriate code and data 8 AOS to the executable file 8A01 at a 
predetermined location. The injection mechanism then modifies the application 
code entry point indicator 8A03 to point to the newly added security code. In 
addition to injecting security code and data 8A05, the injection mechanism 
encrypts some portion of the original application executable code to further 

20 prevent tampering with the modified executable file. In addition, checksums are 
computed on certain portions of the executable file, to be discussed further 
below, which are then encrypted and stored as the injected security data shown as 
part of section 8A05 in Figure 8A. Preferably, the injected security code is 
stored in a predetermined location and the injected encrypted data is stored at 

25 another predetermined location, which is preferably not publicized but is kept 
track of by the injection mechanism. The injection mechanism also inserts a 
transfer of control instruction back to the application executable code in the 
security code and data section 8 AOS. The location transferred to is preferably the 
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original application executable code entry point combined with the size of the 
code encrypted starting with the entry point 8A06. That is, the transfer of control 
should occur to the first unencrypted location after the original code entry point. 

Figure 8B is a block diagram of the logical layout of an executable 

5 file after security code has been injected into the executable file using the DLL 
loader code technique. Executable file 8B10 contains a code entry point 
indicator located at address "xxx," encrypted application code 8B16 ; unencrypted 
application code 8B17, injected DLL loader code 8B13, which refers to an 
injected DLL 8B11, and injected security code and data 8B14. The executable 

10 file 8B10 is shown after being modified to include the DLL loader code 8B13 as 
discussed with reference to Figure 6. Thus, the application entry point indicator 
8B12 has already been modified to point to the injected DLL loader code 8B13. 
Thus, when the executable file is executed, the DLL loader code 8B13 will be 
executed first. However, in Figure 6, the DLL loader code contained a transfer 

15 instruction to transfer control back to the original application executable code 
entry point. In the case shown in Figure 8B, where security code will also be 
injected, this transfer instruction is not added at that point. Instead, after the 
security code and data 8B14 are injected into the executable file SB10 ? a transfer 
instruction is added to transfer control back to the original application entry point 

20 plus encrypted data 8B15, which points to the first instruction in the executable 
code image that appears after the encryption 'code portion 8B16. According to 
this technique, then, the injected security code preferably directly follows the 
loader code so that it is immediately executed after the injected DLL is loaded by 
the operating system. However, one skilled in the art will recognize that other 

25 techniques are possible instead of depending upon order, including transferring 
control from the loader code to a predetermined location where the injected 
security code is stored. In Figure 8B as in Figure 8A, checksums are computed 
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on various pieces of the executable file and stored at a predetermined location 
within the executable file 8B10. 

Figure 9 is an overview flow diagram of the steps performed by the 
injection mechanism for injecting security code and data into an executable file. 
5 The injection mechanism performs and stores checksums and inserts security 
code into an executable file. Specifically, in step 901, the injection mechanism 
performs checksums on various components and saves them in addition to saving 
the original application code entry point. Preferably, a checksum is computed on 
the import table and a checksum is computed on a small range of the injected 

10 DLL image. So. for example, in the case where a licensing DLL is the injected 
DLL, some portion of the licensing code is likely part of the range of the 
checksum. The small range ensures that the speed of the calculation of 
checksums is fast, but that the mechanism still accomplishes its security goals. 
The range of the injected DLL to be checksummed is preferably not publicized 

15 and is determined by (and can be changed by) the programmer using the injection 
mechanism. The checksum operation can be provided by any standard 
checksumming routine that reads a portion of the data, logically combines the 
data portion with a mask, and adds the combined data to a compounded 
checksum result. For example, Table 1 below provides a sample checksum 

20 algorithm: 

Table 1 

for each portion of data of a total amount to be checksummed 

x = read (portion of data); 

result = AND (x, mask); 
25 checksum = checksum + result; 

endfor; 

In step 902, the routine encrypts the computed checksums and the saved 
application code entry point and stores the encrypted information in a 
30 predetermined location, which also is preferably not disclosed. Note that either 
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the various checksums and the application entry point can be encrypted all at 
once and decrypted all at once or they can be encrypted and subsequently 
decrypted using a separate key for each item. In addition, the data can be 
encrypted and decrypted according to an incremental encryption and decryption 
5 technique, which is discussed further below with reference to Figures 10, 11, 12, 
and 14. 

In step 903, the inject security code routine calls an incremental 
encryption routine to encrypt portions of the executable code stored in the 
executable file. The amount of the executable code to be encrypted is preferably 

10 not publicized, is small, and can be modified by the programmer using the 
injection mechanism, A small portion ensures that the speed of the encryp^ 00 
and decryption is fast, but that the mechanism still accomplishes its security 
goals. In step 904, the routine determines where the executable code is located 
within the executable file. In step 905 ; the routine adds checksum verification 

15 code to a predetermined location within the located executable code. This 
checksum verification code is stored as part of the injected security code and data 
8A05 and 8B14 shown in Figures 8A and 8B, respectively. In step 906, the 
routine adds incremental decryption code to a predetermined location within the 
located executable code. This incremental decryption code is also part of the 

20 injected security code shown as 8A05 and 8B14 in Figures 8A and 8B, 
respectively. In step 907, the injection mechanism adds code to retrieve the 
encrypted data (which was encrypted in step 902 and stored in the injected 
security code 8A05 and 8B14 shown in Figures 8A and 8B), and adds code to 
transfer control to the saved application entry point taking into account the size 

25 of the encrypted portion of the executable code. In step 908, the routine adjusts 
any relocatable addresses as necessary due to the addition of the code and data 
shown as injected security code and data 8 AO 5 and 8B14 in Figures 8 A and 8B, 
and returns. 
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Note that, in step 909, other security checks can be added to the 
located executable code at some points within this injection procedure. 
Preferably, security checks, such as making sure the program is running in a 
particular mode, are added to the inject security code routine in an unpublicized 
5 ordering of steps. Thus, the ellipses . in Figure 9 represent that step 907 is 
added somewhere in this process. In a preferred embodiment, the injection 
mechanism performs a check to make sure the process is not in debug mode and, 
if so, aborts execution of the executable file. This prevents any undesired 
viewing of the executable code and security code, which can be used to create an 

io unsecured, or unmodified version of the executable code. 

Figure 10 is a flow diagram of the steps executed by an incremental 
encryption routine. The incremental encryption routine is invoked, for example 
in step 903, as part of the injection of the security code to encrypt portions of the 
executable code stored within the executable file. In step 1001. the routine calls 

15 a subroutine to determine the size (and location) of the blocks of data that will be 
encrypted. According to preferred techniques, the encrypted blocks are variable 
size and the determination routine will compute and store the size for each block. 
The determination routine is discussed in more detail with reference to 
Figures 11 and 12. In step 1002, the routine begins a loop to encrypt the 

20 determined number of blocks starting with the first block. In step 1003. the 
routine sets the encryption key to a predetermined set of flags (registers) which 
represent the CPU state as it will exist when the injected incremental decryption 
code (added in step 906 in Figure 9) is executed by the system, i.e., when the 
executable file is executed. 

25 In particular, the injection mechanism preferably does not publicize 

the particular flags used as a key. Any flags can serve this purpose as long as 
they meet the following criteria: 
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1 . The flags do not vary from system to system, 
or from run of the executable file to run. 

2. The flags can be fairly easily predicted. 

3. Flags can be chosen based upon a "mode" in 
5 which the application will execute. 

An example of a flag that does not meet the first criteria is a flag that counts the 
total number of executions since power-up, because the total number of 
executions since power-up can vary dramatically from system to system. An 
example of a flag that does not meet the second criteria is the CPU instruction 

10 counter, because where the executable code is physically located in memory 
when it is loaded will vary. An example of a flag based upon a mode is whether 
the process is executing in "user mode" or "protected mode" on an Intel 
processor. Preferably, the injection mechanism does not publicize the exact flags 
used and how they are combined so that it is more difficult to break into and 

15 unmodify the executable file with injected code. Any key that meets these 
criteria preferably will be operable within the injection mechanism. 

In step 1004, the incremental encryption routine encrypts the 
current block of data using the determined key for the block size that was 
specifically determined for that block in step 1001. Note that any known 

20 encryption routine can preferably be used with the injection mechanism of the 
present invention. In one preferred embodiment, a basic permutation encryption 
algorithm is utilized. Permutation encryption algorithms, as well as many other 
types of algorithms, are described in detail in Bruce Schneier, Applied 
Cryptography, 2d ed, John Wiley & Sons, 1996, which is hereby incorporated by 

25 reference. In essence, a permutation encryption routine reorders the bits within 
the data block being encrypted using a mathematical algorithm that can be 
duplicated in reverse. Also, for the purposes of the present invention, it is 
assumed that the encrypted data produced by the chosen algorithm is the exact 
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same size as the original data. However, one skilled in the art, will recognize that 
any encryption technique can be utilized including those that change the size of 
the encrypted data from the original data. In that case, the differences in size 
must be tracked and accounted for by the injection mechanism, especially in the 

5 encryption and decryption routines and in the adjustment of relocatable addresses 
step performed by many of the routines. In step 1005, if the encryption algorithm 
does not add a terminating character to the block encrypted, then the injection 
mechanism preferably does so. In an alternative embodiment, the encryption and 
decryption routines keep track of the size of each block and incorporate this size 

10 into the decryption procedure. In step 1006, the incremental encryption routine 
writes the encrypted block of data into the executable file at the same location 
where the unencrypted block was. In this way, the injection mechanism replaces 
the original executable code image with encrypted versions of the image. In step 
1007, the routine checks to see if there are any more blocks that need to be 

15 encrypted and, if so, returns to the beginning of the loop at step 1002 to process 
the next block, else returns. 

Figure 1 1 is a detailed flow diagram of the steps performed by the 
injection mechanism to determine the number and size of the encryption blocks 
of data to be encrypted using the incremental encryption technique. The 

20 Determine Encryption Blocks routine takes as input a projected number of blocks 
and a default size desired for each block." (The default size may also be 
hardcoded or calculated.) The incremental encryption and decryption process 
operates on the principle that only a portion of the data to be encrypted should be 
encrypted or decrypted at any one time so that it is more difficult to break 

25 through the encryption. Because the data is preferably never fully decrypted at 
any one time, it is more difficult for a process to cache a copy of the decryp ted 
code in order to produce an unmodified version of the executable file. Thus, the 
role of the Determine Encryption Blocks routine is to determine what part of the 
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data to be encrypted will be placed in each encrypted block and to store this 
information so that the encryption and decryption routines can determine how 
much data to encrypt/decrypt at any one time. 

Also, the Determine Encryption Blocks routine is responsible for 

5 setting up each encrypted block to ensure that each block can be decrypted and 
executed independently from every other block. Thus, the routine constrains the 
blocks such that there is preferably exactly one entry point into the block from 
outside the block (a "fall through") and exactly one exit point out of the block to 
another encrypted code block. Any algorithm capable of maintaining this 

10 constraint could be utilized. For example, in the Determine Encryption Blocks 
routine of Figure 1 1, the routine first scans the non-encrypted execution code and 
adjusts the portion of the code to be encrypted to ensure that there are no 
transfers back into encrypted code from outside. Then, the routine divides the 
data to be encrypted into target blocks and tries to place the maximum amount of 

15 data into each target block, up to the default block size, with two exceptions. The 
exceptions occur when a transfer instruction is encountered. Specifically, when 
the current source data block contains transfer instructions to target locations 
within encrypted code that is located outside of the current block, the size of the 
tarset block is enlarged to encompass the transfer instruction. Similarly, when 

20 the current data block contains a location that is a target of a transfer instruction 
originating in encrypted code that is outside of the current block, the size of the 
target block is enlarged to encompass the transfer instruction. These adjustments 
ensure that, in the decryption process, all instructions that are needed to decrypt a 
particular portion of code are available. 

25 Specifically, in step 1101, the routine scans the portion of the 

source data that is not to be encrypted looking for transfer instructions whose 
target locations occur within the data to be encrypted. When it encounters such a 
transfer instruction, the routine adjusts the size of the area of data to be encrypted 



WO 98/33106 



25 



PCTYUS98/01845 



to stop short of the target location of the transfer instruction. This adjustment 
ensures that there are no transfers into the encrypted data portion from the 
unencrypted data portion. The routine also scans the portion of data to be 
encrypted for transfer instructions with target locations having addresses that 
5 occur before the addresses of the corresponding transfer instructions (backward 
references to encrypted data). When such an instruction is encountered, the 
routine keeps track of both the target location and the location of the transfer 
instruction in order to make target block adjustments later (see steps 1 106-1 108). 
In step 1102, the routine begins a loop to fill target blocks, beginning with the 

10 first target block. In one embodiment, the data to be encrypted is copied into a 
correct size target block in temporary storage. However, one skilled in the an 
will recognize that other techniques are possible, including those that simply 
keep track of the original data and the division into different blocks. In step 
1103, the Determine Encryption Block routine sets the size of the current target 

15 block equal to the default size. In step 1104, the routine determines and keeps 
track of where in the source data the new block begins, as an offset. Assuming 
the source data begins at the code entry point of the executable file, this offset is 
the calculation of the start address (the entry point) of the executable code in the 
executable file plus the sum of the computed sizes of the prior target blocks. 

20 Steps 1105-1110 comprise an inner loop which copies machine 

instructions to the temporary target block by determining how many can be 
transferred and whether there are transfer instructions that will affect the size of 
the current source block. In particular, in step 1105, the routine reads the next 
machine instruction in the source block starting with the first instruction. Since 

25 instruction sizes can vary, the routine preferably makes sure that it reads the 
maximum size instruction possible. In step 1 106, the routine determines whether 
the current instruction is a transfer instruction or the target location of a transfer 
instruction located outside the current source block and, if so, continues in step 
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1107, else continues in step 1109. In step 1107, if the current instruction is a 
transfer instruction, the routine further determines whether the transfer 
instruction is to a target location in an encrypted block that is outside of the 
current target block and, if so, continues in step 1108, else continues in step 

5 1109. (Transfers to locations within the encrypted block do not cause size 
adjustments as they do not constitute additional entries to or exits from the 
current block.) In step 1108, the routine computes a new size for the current 
target block to extend to and include the target location of the transfer instruction 
if the current instruction is a transfer or to extend to and include the 

10 corresponding (saved) transfer instruction if the current instruction is the target 
location of a transfer initiated outside of the current target block, and continues in 
step 1 109. As mentioned, the purpose of this step is to ensure, for use with the 
incremental decryption process, that there are no transfer instructions to an 
encrypted block outside of the current target block and that there are no transfer 

15 instructions from an outside block into the current target block. In step 1 109, the 
routine copies the current instruction to the current target block in the temporary 
storage. In step 1110, the routine determines whether the target block has been 
filled and if so, continues in step 1111, else returns to the beginning of the inner 
loop at step 1105. In step 111L the routine determines whether there are 

20 additional source blocks to encrypt and, if so } continues back to the beginning of 
the outer loop to determine more target blocks in step 1 102, else returns. 

Figure 12 is an example block diagram of the results of 
determining the size of encryption blocks according to the technique of 
Figure 11. The original code 1201 is shown on the left hand side and the 

25 transferred code 1203 is shown on the right hand side. The transferred code is 
referred to as "encrypted code," even though it is not encrypted at this point. 
Referring to Figure 10, once the code is divided into blocks and the block sizes 
are determined, the incremental encryption routine actually encrypts the blocks in 
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step 1004. Original code 1201 contains a series of instructions shown as 
beginning at logical address "x." Three target blocks of the encrypted code 1203 
are shown as Block 1 (1204), Block 2 (1205), and Block 3 (1206). Using the 
steps shown in Figure 11, the instructions located at logical addresses "x" 

5 through logical address "x+60" (instructions 1 - ri) are copied directly to Block 1, 
because they do not contain transfer instructions and because they exactly fill the 
default size of a block, which here is assumed to be 64. The next set of 
instructions from original code 1201 are continued to be copied into target 
Block 2 in the encrypted code 1203. The example shows instruction at logical 

10 address "y" being transferred to the beginning of encrypted Block 3. When the 
routine reaches the instruction at logical address sl y+4," in original code 1201, 
the routine determines that the instruction is a transfer instruction, shown here as 
u jmp y+128." Since the calculation of "y+128 ; " is greater than the default size 
for the block (64), it can be seen that this transfer instruction has a target location 

15 that is outside of the current target block. It can be further noted that the original 
code 1201 at logical address il y+128" is a target location that is also encrypted, 
and therefore Block 3 needs to be extended in size to include the instruction at 
logical address y+128. Next, at logical address "y+8/' the instruction is also a 
transfer instruction, this time to the instruction of target location logical address 

20 "y+136." Again, the original code 1201 at logical address "y+136" is within the 
code area to be encrypted, and therefore Block 3 must once again be extended in 
size to include the instruction of the target location "y+136/' The routine 
continues with copying the instructions from original code 1201 into the target 
block 1203 until it reaches another transfer instruction or until the current size of 

25 now enlarged Block 3 is reached. For example, the instructions located through 
logical address "y+128" are copied over. At logical address "y+132," there is 
another transfer instruction listed as "jmpy+148." This time, the transfer 
instruction to logical address y+148 transfers to an area of the original code 1201 



WO 98/33106 



28 



PCT/US98/01845 



that is not intended to be encrypted, as shown by the dotted line 1207. Thus, in 
this case, Block 3 is not extended in size. Further, since the target block was 
previously enlarged to include the instruction at location y+136, this instruction 
is copied over to Block 3, which terminates the filling of Block 3. 

5 Figure 13 is a detailed flow diagram of the verify checksum code 

added by the injection mechanism to an executable file. Specifically, the inject 
security code portion of the injection mechanism adds the checksum verification 
code in step 905 in Figure 9. The verify checksum code, when executed by the 
application, is responsible for retrieving the encrypted security data, setting up 

10 the data values appropriately, and verifying that the checksums are correct and 
that no tampering with the executable file has taken place. In particular, in step 

1301, the verify checksum routine retrieves the encrypted security data block 
from the predetermined location. As mentioned with reference to Figure 9, it is 
preferable that this location not be publicized, but one skilled in the art will 

15 recognize that, once chosen, the routine that generates the original checksum and 
the routine that verifies the checksum preferably use the same location. In step 

1302, the verify checksum routine decrypts the retrieved security data block. 
This step assumes, as did Figure 9, that all of the security data was encrypted as a 
single data block. As mentioned, one could have encrypted the security data in 

20 individual pieces and the verify checksum routine would need to be changed 
accordingly. In step 1303, the routine stores' the decrypted checksums and the 
previously saved application code entry point. In step 1304, the routine 
computes the same checksums computed in step 901 of Figure 9. These 
checksums preferably include at least the import table and some range of the 

25 injected DLL. In step 1305, the routine compares the newly generated 
checksums to the decrypted checksums. Then, in step 1306, the routine 
determines whether the checksums are the same, and if so returns (or continues 
with processing). Otherwise, if the checksums are not the same, the implication 
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is that the executable file has been tampered with, and thus the verify checksum 
routine returns an error or aborts processing. 

Figure 14 is a detailed flow diagram of the steps performed by 
incremental decryption. The incremental decryption routine decrypts each block 
5 of data previously encrypted and executes each block, one at a time, so that the 
entire code is never decrypted and executed at once. This procedure helps 
prevent any kind of illegitimate caching of the executable code to generate an 
executable file that has not been modified with the injected DLL or security code. 
Recall that the executable code was encrypted into blocks of varying size, and 

10 that each block is guaranteed at this point to contain no transfer instructions to 
encrypted code outside of the block. 

Specifically, in step 1401, the incremental decryption routines 
begins a loop over all of the encrypted blocks beginning with the first block. In 
step 1402, the routine generates a key using the current designated CPU flags. 

15 These flags are the same as discussed relative to the incremental encryption 
routine of Figure 10, and because they do not van 7 , the key can be determined. 
In step 1403, the routine calls a decryption algorithm to decrypt the current block 
using the determined key. The routine also adds a transfer instruction to transfer 
to step 1409 (indicated by "LABEL:") so that once the decrypted block is 

20 executed, the decrypted code will return back to the incremental decryption 
routine. This procedure is discussed further below with reference to steps 
1407-1408. The decryption routine preferably uses the mirror image of the 
algorithm used in the incremental encryption routine of Figure 10. and any 
encryption/decryption algorithm that satisfies this criterion should work. In step 

25 1404, the incremental decryption routine saves the state of the CPU flags in order 
to later on generate the key for the next block. In step 1405, the routine restores 
the saved executable code (application) execution state in order to execute the 
next block of the application code. This value is initialized to the initial 
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executable state of the code, for example null. In step 1406, the routine transfers 
control to the location of the block that was decrypted in step 1403. The 
decrypted code block logic is shown in steps 1407-1408. In step 1407 the 

v decrypted code executes, and in step 1408 the transfer instruction to "LABEL:" 
5 is executed. This transfers control to step 1409 in the incremental decryption 
routine. In step 1409, the routine saves the current application execution state so 
that it knows what state to restore in step 1405 for execution of the next block of 
the application code. In step 1410, the routine restores the CPU flag state that 
was saved in step 1404 to generate the next key for the next block. In step 141 1, 

10 the incremental decryption routine determines whether there are any more blocks 
to decrypt and, if so, continues back to the beginning of the loop in step 1401, 
else continues in step 1412. In step 1412, the routine restores the saved 
application execution state (it is finished executing all of the encrypted 
application code) and then continues processing preferably in the application 

15 execution code that follows the injected incremental decryption code. 

Although the present invention has been described in terms of 
preferred embodiments, it is not intended that the invention be limited to these 
embodiments. Equivalent methods, structures, processes, steps, and other 
modifications within the spirit of the invention fall within the scope of the 

20 invention. The scope of the present invention is defined by the claims which 
follow. 
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CLAIMS 



1 LA method in a computer system for modifying an existing 

2 executable file so that when the executable File is loaded into memory for execution, 

3 control is transferred to an injected dynamic link library prior to transferring control to 

4 a main entry point of the executable file, the executable file having an import table 

5 indicating each dynamic link library to be mapped and loaded into memory when the 

6 executable file is loaded for execution, wherein when a dynamic link library is mapped 

7 into memory a main library function of the dynamic link library is executed, the 
s method comprising: 

9 creating the injected dynamic link library with a main library function, 

10 the main library function for performing a certain behavior that is not part of the 

1 1 unmodified executable file; and 

12 adding to the import table of the executable file an indication of the 

13 injected link library so that when the executable file is loaded into memory control is 

14 transferred to the main library function of the dynamic link library to execute the 

15 certain behavior prior to transferring control to the main entry point of the executable 

16 file. 

1 2. The method of claim 1 wherein the certain behavior is to 

2 determine whether the executable file is authorized to execute on the computer system. 

1 3. The method of claim 2 wherein, when the certain behavior 

2 determines that the executable file is not authorized to execute on the computer 

3 system, the certain behavior terminates execution of the executable file. 

1 4. The method of claim 2 wherein when the certain behavior 

2 determines that the executable file is authorized to execute on the computer system, 
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3 the certain behavior returns from the main library function of the injected dynamic 

4 link library so that control can be transferred to the main entry point of the executable 

5 file. 

1 5. The method of claim 2, further comprising adjusting addresses 

2 within the executable file to account for the size of the added indication of the injected 

3 dynamic link library. 

1 6. A method in a computer system for modifying an executable file 

2 so that when the executable file is loaded into memory for execution, control is 

3 transferred to an injected dynamic link library prior to transferring control to a main 

4 entry point of the executable file, the executable file having an import table indicating 

5 each dynamic link library to be mapped and loaded into memory when the executable 

6 file is loaded for execution, wherein when a dynamic link library is mapped into 

7 memory a main library function of the dynamic link library is executed, the executable 
s file containing a main entry point reference that refers to the main entry point of the 

9 executable file, the method comprising: 

10 adding to the import table of the executable file an indication of the 

11 injected dynamic link library so that, when the executable file is loaded into memory, 

12 control is transferred to the main library function af the injected dynamic link library 

13 to execute a certain behavior prior to transferring control to the main entry point of the 

14 executable file; 

15 replacing a portion of the executable file with an encrypted version of 

16 that portion; 

17 adding to the executable file an encrypted copy of the main entry point 
is reference of the executable file; 

19 adding security code to the executable file; and 
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20 setting the main entry point reference of the executable file to refer to 

21 the added security code, whereby when the modified executable file is executed, 

22 control is transferred to the main library function of the injected dynamic link library 

23 and control is then transferred to the added security code referred to by the main entry 

24 point reference, wherein the added security code: 

25 determines whether tampering has occurred that affects the 

26 execution of the executable file; 

27 when tampering has occurred, terminates execution of the 

28 executable file; and 

29 when tampering has not occurred. 

30 replaces the encrypted portion with a decrypted portion; 

31 and 

32 transfers control to the main entry point of the executable 

33 file. 

1 7. The method of claim 6, further comprising adding a checksum for 

2 the injected dynamic link library to the executable file, wherein the added security 

3 code calculates a checksum for the dynamic link library and compares the calculated 

4 checksum to the added checksum to ensure that the dynamic link library has not been 

5 modified. 

1 8. The method of claim 6, further comprising adding a checksum for 

2 the import table to the executable file, wherein the added security code calculates a 

3 checksum for the import table and compares the calculated checksum to the added 

4 checksum to ensure that the import table has not been modified. 
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1 9. The method of claim 6 wherein the replacement of the encrypted 

2 portion with a decrypted portion uses incremental decryption to decrypt the encrypted 

3 portion into subportions and executes each subportion separately. 

1 10. The method of claim 9 wherein the incremental decryption into 

2 subportions overwrites a previous subportion with a next subportion before executing 

3 the next subportion. 

1 1 1 . A method in a computer system for incrementally decrypting and 

2 executing an encrypted portion of an executable file to ensure that the entire decrypted 

3 portion is not in memory at the same time, the method comprising: 

4 for each of a plurality of subportions of the encrypted portion, 

5 storing a decrypted version of the subportion to overwrite any 

6 previously decrypted version of another subportion; and 

7 executing the stored decrypted version of the subportion. 

1 12. The method of claim 11 wherein the computer system has a 

2 context state and including: 

3 before executing the stored decrypted version of the sub-portion, 

4 saving the context state; and . 

5 setting the context state to a previously saved context state for the 

6 encrypted portion; and 

7 after executing the stored decrypted version of the sub-portion, 

8 saving the context state for the encrypted portion; and 

9 setting the context state to the context state saved before 

10 executing the stored decrypted version. 
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1 13. A method in a computer system for encrypting executable code 

2 into subportions that can be decrypted one at a time, the method comprising: 

3 determining a plurality of source blocks of variable sizes, the size of 

4 each source block ensuring that code to be contained in an encrypted version of the 

5 source block will execute when decrypted without transferring to a location outside the 

6 source block that is encrypted; and 

7 for each determined source block, 

8 ■ determining a key; 

9 encrypting the source block using the determined key; and 

10 copying the encrypted source block into the executable file. 

1 14. The method of claim 13, further comprising: 

2 for each encrypted source block copied into the executable file, 

3 determining a key based upon a context state; 

4 decrypting the source block using the determined key; 

5 ■ storing the decrypted source block to overwrite any previously 

6 decrypted source block; and 

7 executing the stored decrypted source block. 

1 15. A method in a computer system for modifying an executable file 

2 to ensure that a tampered with version of the executable file is not executed, the 

3 executable file containing a main entry point reference that refers to the main entry 

4 point of the executable file, the method comprising: 

5 replacing a portion of the executable file with an encrypted version of 

6 that portion; 

7 adding to the executable file a copy of the main entry point reference of 

8 the executable file; 

9 adding security code to the executable file; and 
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10 setting the main entry point reference of the executable file to refer to 

u the added security code, whereby when the modified executable file is executed, 

12 control is transferred to the added security code referred to by the main entry point 

13 reference, wherein the added security code: 

14 determines whether tampering has occurred that affects the 

15 execution of the executable file; 

16 when tampering has occurred, terminates execution of the 

17 executable file; and 

18 when tampering has not occurred, 

19 replaces the encrypted portion with a decrypted portion; 

20 and 

21 transfers control to the main entry point of the executable 

22 file. 

1 16. The method of claim 15 wherein the added security code replaces 

2 and transfers control to subportions of the encrypted portion. 

1 17. The method of claim 15, further comprising adding a checksum 

2 of a portion of the executable file to the executable file and wherein the added security 

3 code determines whether tampering occurred by recalculating the checksum of the 

4 portion of the executable file and comparing the recalculated checksum to the added 

5 checksum. 



1 18. The method of claim 9 wherein the added copy of the main entry 

2 point reference is encrypted. 

1 19. A method in a computer system for modifying an existing 

2 executable file so that when the executable file is loaded into memory for execution, 
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3 control is transferred to an injected dynamic link library prior to transferring control to 

4 a main entry point of the executable file, the executable file containing a main entry 

5 point reference that refers to the main entry point, the executable file having 

6 executable code, wherein when a dynamic link library is loaded into memory for the 

7 executable file, a main library function of the dynamic link library is executed, the 

8 method comprising: 

9 locating the executable code in the executable file; 

10 adding loader code to the located executable code, the loader code 

1 1 having instructions for loading the injected dynamic link library into memory; 

12 saving the main entry point referred to by the main entry point reference; 

13 adding transfer of control code into a location that follows the added 

14 loader code such that control is transferred to the saved main entry point after the 

15 added loader code is executed; and 

16 setting the main entry point reference to refer to the added loader code. 

1 20. The method of claim 19, further comprising adjusting addresses 

2 within the executable file to account for the sizes of the added loader code and the 

3 added transfer of control code. 

1 21. The method of claim 19 wherein a certain behavior is added to 

2 the injected dynamic link library to determine whether the executable file is authorized 

3 to execute on the computer system. 

1 22. The method of claim 21 wherein, when the certain behavior 

2 determines that the executable file is not authorized to execute on the computer 

3 system, the certain behavior terminates execution of the executable file. 
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1 23. The method of claim 21 wherein, when the certain behavior 

2 determines that the executable file is authorized to execute on the computer system, 

3 the certain behavior returns from a function of the dynamic link library so that control 

4 can be transferred to the main entry point of the executable file. 

1 24. A method in a computer system for modifying an existing 



2 executable file to include a reference to new code that contains a certain behavior so 

3 that, when the executable file is loaded into memory for execution, control is 

4 transferred to the new code with the certain behavior prior to transferring control to a 

5 main entry point of the executable file, the executable file containing a main entry 

6 point reference that refers to the main entry point, the executable file having 

7 executable code, the method comprising: 



8 locating the executable code in the executable file; 

9 adding to the located executable code a reference to the new code with 

10 the certain behavior, the reference causing the new code to be executed; 

1 1 saving the main entry point referred to by the main entry point reference; 

12 adding transfer of control code into a location that follows the added 

13 reference to the new code such that control is transferred to the saved main entry point 

14 after the new code is executed; and 

15 setting the main entry point reference to refer to the added reference to 

16 the new code, so that the new code is executed when the executable file is loaded for 

17 execution. 

1 25. The method of claim 24 wherein the adding of the reference to 

2 the new code comprises modifying a table within the executable file to include a 

3 reference to the new code, the table comprising entries that indicate code to be loaded 

4 when the executable file is loaded. 
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1 26. The method of claim 25 wherein the new code resides in a 

2 dynamic link library. 

1 27. The method of claim 24 wherein the adding of the reference to 

2 the new code comprises adding loader code within the executable file that loads the 

3 new code and transfers execution to a location within the new code. 

1 28. The method of claim 27 wherein the new code resides in a 

2 dynamic link library. 



1 29. The method of claim 24 wherein the certain behavior of the new 

2 code starts and stops another executable code module. 



1 30. The method of claim 29 wherein the executable code is a browser 

2 application. 

1 31. The method of claim 24 wherein the certain behavior of the new 

2 code adds in a user interface component. 

1 32. The method of claim 31 wherein the user interface component is 

2 a menu. 

1 33. A method in a computer system for providing a new behavior to 

2 executable code stored in an existing executable file, the executable file having an 

3 import table indicating each external code library to be mapped and loaded into 

4 memory when the executable file is loaded for execution, each external code library 

5 having at least one function that can be invoked at runtime by the executable code, 

6 wherein when an external code library is mapped and loaded, an initial function within 
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7 the external library is executed prior to execution of the executable code, the method 

8 comprising: 

9 providing a new external code library with an initial function that 
to implements the new behavior; 

1 1 locating the import table in the executable file; and 

12 adding to the located import table a reference to the provided new 

13 external code library, such that, when the executable file is loaded, the initial function 

14 of the new external code library is executed, thereby causing the new behavior to be 

15 performed. 
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